## Inconsistency Issue with Continuous Assignment Error after FSM Optimization using opt dff and Other Passes

I have come across an inconsistency problem during the synthesis process while using Yosys: Version: Icarus Verilog version 13.0, Yosys 0.30+48

In our synthesis flow, we have deviated from using Yosys's default synthesis process and have incorporated additional optimization steps aimed at enhancing the performance, area efficiency, and other key metrics of our design. However, these changes should not affect the consistency of the code.

The two synthesis processes are as follows:

```
1. Using Yosys's default synthesis process:
read verilog rtl.v
synth
write verilog syn yosys.v
2. Customized synthesis process:
read_verilog rtl.v
prep -ifx;
hierarchy;
flatten;
proc -norom;
opt_reduce; opt_clean;
memory share;
opt;
fsm_expand; opt_expr -fine; opt_clean -purge; opt_share; opt_expr -keepdc; opt_dff -nodffe; opt_expr;
abc;
write_verilog syn_yosys.vv
```

After obtaining synthesis files from both of the above processes, I performed simulation verification using the Iverilog simulator. However, I observed inconsistencies in the output signals during simulation, as highlighted in the red-boxed section in the image below.

Default synthesis process, the first second of output is:

```
on$ vvp -n wave_1 -lxt2
```

Figure 1: Before Modification

```
question$ vvp -n wave_2 -lxt2
8600018000386000860008000086000880003860008800088000880008800088000880008800
8000880008800088000800080001100888008880088800888008888088880888
```

Figure 2: After Modification